<!DOCTYPE html>
<html lang="zh-CN">





<head>
  <meta charset="UTF-8">
  <link rel="apple-touch-icon" sizes="76x76" href="https://s2.ax1x.com/2020/01/23/1EwDcq.png">
  <link rel="icon" type="image/png" href="https://s2.ax1x.com/2020/01/23/1EwDcq.png">
  <meta name="viewport"
        content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no, shrink-to-fit=no">
  <meta http-equiv="x-ua-compatible" content="ie=edge">
  
  <meta name="description" content="">
  <meta name="author" content="Fansure Grin">
  <meta name="keywords" content="share,hexo,blog,博客,分享">
  <title>Ubuntu中搭建Hexo博客记录（上篇） | Fansure的小栈</title>

  <link rel="stylesheet" href="/lib/font-awesome/css/all.min.css"  >
<link rel="stylesheet" href="/lib/bootstrap/css/bootstrap.min.css"  >
<link rel="stylesheet" href="/lib/mdbootstrap/css/mdb.min.css"  >
<link rel="stylesheet" href="/lib/github-markdown/github-markdown.min.css"  >

<link rel="stylesheet" href="//at.alicdn.com/t/font_1067060_qzomjdt8bmp.css">



  <link rel="stylesheet" href="/lib/prettify/tomorrow-night-eighties.min.css"  >

<link rel="stylesheet" href="/css/main.css"  >


  <link rel="stylesheet" href="/lib/fancybox/jquery.fancybox.min.css"  >


<meta name="generator" content="Hexo 4.2.0"></head>


<body>
  <header style="height: 70vh;">
    <nav id="navbar" class="navbar fixed-top  navbar-expand-lg navbar-dark scrolling-navbar">
  <div class="container">
    <a class="navbar-brand"
       href="/">&nbsp;<strong>Fansure的小栈</strong>&nbsp;</a>

    <button id="navbar-toggler-btn" class="navbar-toggler" type="button" data-toggle="collapse"
            data-target="#navbarSupportedContent"
            aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
      <div class="animated-icon"><span></span><span></span><span></span></div>
    </button>

    <!-- Collapsible content -->
    <div class="collapse navbar-collapse" id="navbarSupportedContent">
      <ul class="navbar-nav ml-auto text-center">
        
          
          
          
          
          <li class="nav-item">
            <a class="nav-link" href="/">首页</a>
          </li>
        
          
          
          
          
          <li class="nav-item">
            <a class="nav-link" href="/archives/">归档</a>
          </li>
        
          
          
          
          
          <li class="nav-item">
            <a class="nav-link" href="/categories/">分类</a>
          </li>
        
          
          
          
          
          <li class="nav-item">
            <a class="nav-link" href="/tags/">标签</a>
          </li>
        
          
          
          
          
          <li class="nav-item">
            <a class="nav-link" href="/about/">关于</a>
          </li>
        
        
          <li class="nav-item" id="search-btn">
            <a class="nav-link" data-toggle="modal" data-target="#modalSearch">&nbsp;&nbsp;<i
                class="iconfont icon-search"></i>&nbsp;&nbsp;</a>
          </li>
        
      </ul>
    </div>
  </div>
</nav>

    <div class="view intro-2" id="background"
         style="background: url('https://up.enterdesk.com/edpic_source/98/80/c8/9880c85e173b4b1d3daa8b931c3c9d0f.jpg')no-repeat center center;
           background-size: cover;
           background-attachment: fixed;">
      <div class="full-bg-img">
        <div class="mask rgba-black-light flex-center">
          <div class="container text-center white-text fadeInUp">
            <span class="h2" id="subtitle">
              
            </span>

            
              <br>
              
                <p class="mt-3">
                  <i class="fas fa-calendar-alt" aria-hidden="true"></i>&nbsp;
                  星期二, 二月 11日 2020, 11:23 上午
                </p>
              

              <p>
                
                  
                  &nbsp;<i class="far fa-chart-bar"></i>
                  <span class="post-count">
                    1.4k 字
                  </span>&nbsp;
                

                
                  
                  &nbsp;<i class="far fa-clock"></i>
                  <span class="post-count">
                      5 分钟
                  </span>&nbsp;
                

                
                  <!-- 不蒜子统计文章PV -->
                  
                  &nbsp;<i class="far fa-eye" aria-hidden="true"></i>&nbsp;
                  <span id="busuanzi_container_page_pv">
                    <span id="busuanzi_value_page_pv"></span> 次
                  </span>&nbsp;
                
              </p>
            
          </div>

          
        </div>
      </div>
    </div>
  </header>

  <main>
    
      

<div class="container-fluid">
  <div class="row">
    <div class="d-none d-lg-block col-lg-2"></div>
    <div class="col-lg-8 nopadding-md">
      <div class="py-5 z-depth-3" id="board">
        <div class="post-content mx-auto" id="post">
          <div class="markdown-body">
            <p>##1.Hexo部署前的环境准备</p>
<p>安装hexo之前需要准备好一些必要的环境，参照着Hexo官网的文档一步一步来即可。</p>
<p>Hexo官网：<a href="https://hexo.io" target="_blank" rel="noopener">https://hexo.io</a></p>
<p>官方文档提示需要安装nodejs和Git，其中nodejs的版本不能低于8.10，推荐10.0及以上。其实，这里的nodejs中还包括了npm这个包管理器，用来下载安装Hexo的。如果下载的nodejs中没有npm的话还需要安装npm，当然这是后续之需，我们先来下载nodejs吧！</p>
<h3 id="第一步，安装NodeJs："><a href="#第一步，安装NodeJs：" class="headerlink" title="第一步，安装NodeJs："></a>第一步，安装NodeJs：</h3><ul>
<li><p>NodeJs官网：<a href="https://nodejs.org" target="_blank" rel="noopener">https://nodejs.org</a></p>
</li>
<li><p>NodeJs中文官网： <a href="https://nodejs.org/zh-cn/" target="_blank" rel="noopener">https://nodejs.org/zh-cn/</a></p>
</li>
</ul>
<p>安装nodejs的方法也很多，这里总结了四种：</p>
<h4 id="①在nodejs官网下载安装包，解压后进行环境配置：具体过程可以参考这篇文章：Ubuntu安装Nodejs（通过官方tar-xz文件）"><a href="#①在nodejs官网下载安装包，解压后进行环境配置：具体过程可以参考这篇文章：Ubuntu安装Nodejs（通过官方tar-xz文件）" class="headerlink" title="①在nodejs官网下载安装包，解压后进行环境配置：具体过程可以参考这篇文章：Ubuntu安装Nodejs（通过官方tar.xz文件）"></a>①在nodejs官网下载安装包，解压后进行环境配置：具体过程可以参考这篇文章：<a href="https://blog.csdn.net/darkwindzzh/article/details/82192704" target="_blank" rel="noopener">Ubuntu安装Nodejs（通过官方tar.xz文件）</a></h4><p>官方的tar.xz文件可以在这个页面下载： <a href="https://nodejs.org/en/download/" target="_blank" rel="noopener">https://nodejs.org/en/download/</a></p>
<p><img src="https://s2.ax1x.com/2020/02/09/1flngI.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>这样安装之后是带有npm的。</p>
<h4 id="②通过官方源码编译安装：可以参考这篇文章-gt-Node–Ubuntu下源码编译安装Node-js"><a href="#②通过官方源码编译安装：可以参考这篇文章-gt-Node–Ubuntu下源码编译安装Node-js" class="headerlink" title="②通过官方源码编译安装：可以参考这篇文章-&gt;Node–Ubuntu下源码编译安装Node.js"></a>②通过官方源码编译安装：可以参考这篇文章-&gt;Node–Ubuntu下源码编译安装Node.js</h4><p>源码下载地址： <a href="https://nodejs.org/en/download/" target="_blank" rel="noopener">https://nodejs.org/en/download/</a></p>
<p><img src="https://s2.ax1x.com/2020/02/09/1f1KJJ.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<h4 id="③通过apt或者apt-get包管理器安装，"><a href="#③通过apt或者apt-get包管理器安装，" class="headerlink" title="③通过apt或者apt-get包管理器安装，"></a>③通过<code>apt</code>或者<code>apt-get</code>包管理器安装，</h4><p>首先，更新本地的apt软件源为国内源，这样速度较快，更改软件源可以通过图形化界面更改，也可以通过命令行更改。</p>
<ul>
<li>·1· 通过图形化界面更改：打开Ubuntu自带的软件和更新软件，修改软件源为国内源，如阿里源(mirrors.aliyun.com)、清华源(mirrors.tuna.tsinghua.edu.cn)、中科大源(mirrors.ustc.edu.cn)等等</li>
</ul>
<p><img src="https://s2.ax1x.com/2020/02/09/1f3Bh4.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1f30NF.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<ul>
<li>·2· 通过命令行修改：</li>
</ul>
<p>终端切换目录到 <code>/etc/apt/</code>，修改source.list文件(使用<code>vim</code>或<code>vi</code>编辑器，好像ubuntu自带vi编辑器吧~，vim是我自己安装的)</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1f8uvR.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1f8eC4.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1f8m8J.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>那么source.list中填写些什么东西呢？不能乱填，要填软件源地址：这里列举几个</p>
<p>清华源：软件源获取地址： <a href="https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/" target="_blank" rel="noopener">https://mirrors.tuna.tsinghua.edu.cn/help/ubuntu/</a> ，选择你系统对应的版本复制过来即可</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1f8xZ6.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>阿里源：软件源获取地址： <a href="https://developer.aliyun.com/mirror/ubuntu?spm=a2c6h.13651102.0.0.3e221b11WgsqlI" target="_blank" rel="noopener">https://developer.aliyun.com/mirror/ubuntu?spm=a2c6h.13651102.0.0.3e221b11WgsqlI</a></p>
<p>软件源更改后来一个 sudo apt update 更新本地软件源缓存，我下面是已经更新过的：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fGIOI.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>然后执行命令 <code>sudo apt install nodejs</code> 安装nodejs：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fJikT.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1fJkhF.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>然后，验证是否安装成功，执行命令 <code>node -v</code> 查看nodejs版本信息：是8.10版本，最低要求的版本，可以的。如果想要最新版可以尝试上面的两种方法和后面要介绍的那种方法。</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fJNnI.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<h4 id="④通过apt安装高版本的nodejs：通过国内源安装的大部分都是8-10版本的，而现在最新的LTS-长期支持版本-是-12-15-0-了，当然你可以通过前两个方法安装上12-15-0版本，这里介绍的还是通过apt软件源在线安装。"><a href="#④通过apt安装高版本的nodejs：通过国内源安装的大部分都是8-10版本的，而现在最新的LTS-长期支持版本-是-12-15-0-了，当然你可以通过前两个方法安装上12-15-0版本，这里介绍的还是通过apt软件源在线安装。" class="headerlink" title="④通过apt安装高版本的nodejs：通过国内源安装的大部分都是8.10版本的，而现在最新的LTS(长期支持版本)是 12.15.0 了，当然你可以通过前两个方法安装上12.15.0版本，这里介绍的还是通过apt软件源在线安装。"></a>④通过apt安装高版本的nodejs：通过国内源安装的大部分都是8.10版本的，而现在最新的LTS(长期支持版本)是 12.15.0 了，当然你可以通过前两个方法安装上12.15.0版本，这里介绍的还是通过apt软件源在线安装。</h4><p>方法就是请求nodejs托管在Github上的仓库进行安装： <a href="https://github.com/nodesource/distributions/blob/master/README.md" target="_blank" rel="noopener">https://github.com/nodesource/distributions/blob/master/README.md</a></p>
<p>如何做呢？上一行的链接中提供了方法，两行命令搞定，不过执行命令之前要选择自己需要的版本：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fYQrn.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>我就选择这个12.X版本吧~</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fYYPU.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>如果像我一样没有安装curl，那就通过 sudo apt install curl 安装一个吧，又不会怀孕是吧…</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fY2xH.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1fY7i8.png" srcset="/img/loading.gif" alt="请输入图片描述"><br><img src="https://s2.ax1x.com/2020/02/09/1fYfsA.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>安装curl后，再执行命令：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fY5Zt.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>妈惹法克，这是咋回事呢！！！！！估计GFW对这个地址有什么意见吧。。。。（佛了。。）,俺再试一次：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1ftRYT.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>行了！接下来 <code>sudo apt-get install -y nodejs</code> 安装：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fYOMj.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>后来。。。居然卡住了，速度太慢了。。。。后来就没有试了</p>
<h4 id="⑤-上面几种方法都使我不大满意，于是乎，我找到了nvm在这款工具："><a href="#⑤-上面几种方法都使我不大满意，于是乎，我找到了nvm在这款工具：" class="headerlink" title="⑤.上面几种方法都使我不大满意，于是乎，我找到了nvm在这款工具："></a>⑤.上面几种方法都使我不大满意，于是乎，我找到了nvm在这款工具：</h4><blockquote>
<p> nvm全称Node Version Manager是 Nodejs 版本管理器，它让我们能方便的对 Nodejs 的版本进行切换。 nvm<br>的官方版本只支持 Linux 和 Mac。 Windows 用户，可以用 nvm-windows。</p>
<p>来自 <a href="https://juejin.im/post/5c03a27d51882523d3166be0" target="_blank" rel="noopener">https://juejin.im/post/5c03a27d51882523d3166be0</a></p>
</blockquote>
<ul>
<li><p>nvm的github仓库地址为 <a href="https://github.com/creationix/nvm" target="_blank" rel="noopener">https://github.com/creationix/nvm</a></p>
</li>
<li><p>如何在Ubuntu上安装nvm呢：参考 <a href="https://github.com/nvm-sh/nvm#installing-and-updating" target="_blank" rel="noopener">https://github.com/nvm-sh/nvm#installing-and-updating</a> 和<a href="https://blog.csdn.net/u010942902/article/details/88410978" target="_blank" rel="noopener">https://blog.csdn.net/u010942902/article/details/88410978</a></p>
</li>
</ul>
<h5 id="1-在终端执行以下任意一条命令，将自动进行nvm的安装："><a href="#1-在终端执行以下任意一条命令，将自动进行nvm的安装：" class="headerlink" title="1. 在终端执行以下任意一条命令，将自动进行nvm的安装："></a>1. 在终端执行以下任意一条命令，将自动进行nvm的安装：</h5><pre><code>curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.2/install.sh | bash 
或者
wget -qO- https://raw.githubusercontent.com/nvm-sh/nvm/v0.35.2/install.sh | bash </code></pre><p>我用的是后者，等了1分钟左右安装完成。</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fsQEQ.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>之后，重新打开终端， 重新打开终端 ， 重新打开终端 ！！！要不然还是提示nvm not found！重新打开终端后，输入 nvm -v，显示版本，说明安装成功：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fyuxx.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<h5 id="2-用nvm安装nodejs："><a href="#2-用nvm安装nodejs：" class="headerlink" title="2.用nvm安装nodejs："></a>2.用nvm安装nodejs：</h5><pre><code>nvm ls-remote         #查看远端仓库中的nodejs版本 
nvm ls                #查看本地安装的nodejs版本
nvm install [version] #安装指定版本的nodejs</code></pre><p><img src="https://s2.ax1x.com/2020/02/09/1f6EOf.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>我安装了12.15.0版本，并且自带一个6.13.4版本的npm：</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1f6Whd.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p>不管如何搞，Nodejs的安装就到这里，选择合适的方法安装即可。</p>
<h3 id="第二步，安装npm："><a href="#第二步，安装npm：" class="headerlink" title="第二步，安装npm："></a>第二步，安装npm：</h3><p>通过几种安装方法的实验，我最终采用的是用nvm来管理nodejs的，nodejs安装在 <code>/home/用户名/.nvm/versions/node/</code> 文件夹下。nodejs里面自带npm，我就不再安装npm啦~</p>
<p>如果你是通过 <code>sudo apt install nodejs</code> 安装的，然后没有npm的话，可以执行命令 <code>sudo apt install npm</code> 来安装一下。</p>
<h3 id="第三步，安装Git："><a href="#第三步，安装Git：" class="headerlink" title="第三步，安装Git："></a>第三步，安装Git：</h3><p>首先，查看你的系统有没有git，终端来一个 git 命令，不用我说了吧，提示 <code>“Command &#39;git&#39; not found“</code>，那就 <code>sudo apt install git</code>。</p>
<p><img src="https://s2.ax1x.com/2020/02/09/1fhV8e.png" srcset="/img/loading.gif" alt="请输入图片描述"></p>
<p><strong>至此环境搭建完成！！！</strong></p>

            <hr>
          </div>
          <br>
          <div>
            <p>
            
              <span>
                <i class="iconfont icon-inbox"></i>
                
                  <a class="hover-with-bg" href="/categories/%E5%8D%9A%E5%AE%A2%E6%90%AD%E5%BB%BA">博客搭建</a>
                  &nbsp;
                
              </span>&nbsp;&nbsp;
            
            
              <span>
                <i class="iconfont icon-tag"></i>
                
                  <a class="hover-with-bg" href="/tags/%E5%8D%9A%E5%AE%A2%E6%90%AD%E5%BB%BA">博客搭建</a>
                
              </span>
            
            </p>
            
              <p class="note note-warning">本博客所有文章除特别声明外，均采用 <a href="https://zh.wikipedia.org/wiki/Wikipedia:CC_BY-SA_3.0%E5%8D%8F%E8%AE%AE%E6%96%87%E6%9C%AC" target="_blank" rel="nofollow noopener noopener">CC BY-SA 3.0协议</a> 。转载请注明出处！</p>
            
          </div>
        </div>
      </div>
    </div>
    <div class="d-none d-lg-block col-lg-2 toc-container">
      
  <div id="toc">
    <p class="h4"><i class="far fa-list-alt"></i>&nbsp;目录</p>
    <div id="tocbot"></div>
  </div>

    </div>
  </div>
</div>

<!-- custom -->


<!-- Comments -->
<div class="col-lg-7 mx-auto nopadding-md">
  <div class="container comments mx-auto" id="comments">
    
      <br><br>
      
      
  <div id="vcomments" style="width: 90%; margin: 0 auto;"></div>
  <script defer src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script>
  <script defer src="//unpkg.com/valine/dist/Valine.min.js"></script>

  <script>
    var notify = 'false' === true;
    var verify = 'false' === true;
    var oldLoad = window.onload;
    window.onload = function () {
      new Valine({
        el: '#vcomments',
        notify: notify,
        verify: verify,
        app_id: "DySPQjS0lPUGBNigiGPGXDbU-gzGzoHsz",
        app_key: "HNYP8577C8AqC85sSrQVzwQy",
        placeholder: "快快挥霍你的口水吧~",
        avatar: "retro",
        meta: ['nick', 'mail', 'link'],
        pageSize: "10",
      });
      oldLoad && oldLoad();
    };
  </script>
  <noscript>Please enable JavaScript to view the <a href="https://valine.js.org" target="_blank" rel="nofollow noopener noopener">comments
      powered by Valine.</a></noscript>


    
  </div>
</div>

    
  </main>

  
    <a class="z-depth-1" id="scroll-top-button" href="#" role="button">
      <i class="fa fa-chevron-up scroll-top-arrow" aria-hidden="true"></i>
    </a>
  

  
    <div class="modal fade" id="modalSearch" tabindex="-1" role="dialog" aria-labelledby="ModalLabel"
     aria-hidden="true">
  <div class="modal-dialog modal-dialog-scrollable modal-lg" role="document">
    <div class="modal-content">
      <div class="modal-header text-center">
        <h4 class="modal-title w-100 font-weight-bold">搜索</h4>
        <button type="button" id="local-search-close" class="close" data-dismiss="modal" aria-label="Close">
          <span aria-hidden="true">&times;</span>
        </button>
      </div>
      <div class="modal-body mx-3">
        <div class="md-form mb-5">
          <input type="text" id="local-search-input" class="form-control validate">
          <label data-error="x" data-success="v"
                 for="local-search-input">关键词</label>
        </div>
        <div class="list-group" id="local-search-result"></div>
      </div>
    </div>
  </div>
</div>
  

  <footer class="mt-5">
  <div class="text-center py-3">
    <a href="https://hexo.io" target="_blank" rel="nofollow noopener"><b>Hexo</b></a>
    <i class="iconfont icon-love"></i>
    <a href="https://github.com/fluid-dev/hexo-theme-fluid" target="_blank" rel="nofollow noopener"> <b>Fluid</b></a>
    <br>

    
  
    <!-- 不蒜子统计PV -->
    
    &nbsp;<span id="busuanzi_container_site_pv">总访问量 
          <span id="busuanzi_value_site_pv"></span> 次</span>&nbsp;
  
  
    <!-- 不蒜子统计UV -->
    
    &nbsp;<span id="busuanzi_container_site_uv">总访客数 
            <span id="busuanzi_value_site_uv"></span> 人</span>&nbsp;
  
  <br>



    


    <!-- cnzz Analytics icon -->
    

  </div>
</footer>

<!-- SCRIPTS -->
<script src="/lib/jquery/jquery.min.js" ></script>
<script src="/lib/popper/popper.min.js" ></script>
<script src="/lib/bootstrap/js/bootstrap.min.js" ></script>
<script src="/lib/mdbootstrap/js/mdb.min.js" ></script>
<script src="/js/main.js" ></script>


  <script src="/js/lazyload.js" ></script>



  
    <script src="/lib/tocbot/tocbot.min.js" ></script>
  
  <script src="/js/post.js" ></script>



  <script src="/lib/smooth-scroll/smooth-scroll.min.js" ></script>



  <script async src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js" ></script>


<!-- Plugins -->


  

  

  

  

  <!-- cnzz Analytics -->
  



  <script src="/lib/prettify/prettify.min.js" ></script>
  <script>
    $(document).ready(function () {
      $('pre').addClass('prettyprint  linenums');
      prettyPrint();
    })
  </script>



  <script src="/lib/typed/typed.min.js" ></script>
  <script>
    var typed = new Typed('#subtitle', {
      strings: [
        '  ',
        "Ubuntu中搭建Hexo博客记录（上篇）&nbsp;",
      ],
      cursorChar: "_",
      typeSpeed: 70,
      loop: false,
    });
    typed.stop();
    $(document).ready(function () {
      $(".typed-cursor").addClass("h2");
      typed.start();
    });
  </script>



  <script src="/lib/anchor/anchor.min.js" ></script>
  <script>
    anchors.options = {
      placement: "right",
      visible: "false",
      
    };
    var el = "h1,h2,h3,h4,h5,h6".split(",");
    var res = [];
    for (item of el) {
      res.push(".markdown-body > " + item)
    }
    anchors.add(res.join(", "))
  </script>



  <script src="/js/local-search.js" ></script>
  <script>
    var path = "/local-search.xml";
    var inputArea = document.querySelector("#local-search-input");
    inputArea.onclick = function () {
      getSearchFile(path);
      this.onclick = null
    }
  </script>



  <script src="/lib/fancybox/jquery.fancybox.min.js" ></script>
  <script>
    $("#post img:not(.no-zoom img, img[no-zoom])").each(
      function () {
        var element = document.createElement("a");
        $(element).attr("data-fancybox", "images");
        $(element).attr("href", $(this).attr("src"));
        $(this).wrap(element);
      }
    );
  </script>





  
  
    <script>
      !function (e, t, a) {
        function r() {
          for (var e = 0; e < s.length; e++) s[e].alpha <= 0 ? (t.body.removeChild(s[e].el), s.splice(e, 1)) : (s[e].y--, s[e].scale += .004, s[e].alpha -= .013, s[e].el.style.cssText = "left:" + s[e].x + "px;top:" + s[e].y + "px;opacity:" + s[e].alpha + ";transform:scale(" + s[e].scale + "," + s[e].scale + ") rotate(45deg);background:" + s[e].color + ";z-index:99999");
          requestAnimationFrame(r)
        }

        function n() {
          var t = "function" == typeof e.onclick && e.onclick;
          e.onclick = function (e) {
            t && t(), o(e)
          }
        }

        function o(e) {
          var a = t.createElement("div");
          a.className = "heart", s.push({
            el: a,
            x: e.clientX - 5,
            y: e.clientY - 5,
            scale: 1,
            alpha: 1,
            color: c()
          }), t.body.appendChild(a)
        }

        function i(e) {
          var a = t.createElement("style");
          a.type = "text/css";
          try {
            a.appendChild(t.createTextNode(e))
          } catch (t) {
            a.styleSheet.cssText = e
          }
          t.getElementsByTagName("head")[0].appendChild(a)
        }

        function c() {
          return "rgb(" + ~~(255 * Math.random()) + "," + ~~(255 * Math.random()) + "," + ~~(255 * Math.random()) + ")"
        }

        var s = [];
        e.requestAnimationFrame = e.requestAnimationFrame || e.webkitRequestAnimationFrame || e.mozRequestAnimationFrame || e.oRequestAnimationFrame || e.msRequestAnimationFrame || function (e) {
          setTimeout(e, 1e3 / 60)
        }, i(".heart{width: 10px;height: 10px;position: fixed;background: #f00;transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);}.heart:after,.heart:before{content: '';width: inherit;height: inherit;background: inherit;border-radius: 50%;-webkit-border-radius: 50%;-moz-border-radius: 50%;position: fixed;}.heart:after{top: -5px;}.heart:before{left: -5px;}"), n(), r()
      }(window, document);
    </script>
  







</body>
</html>
